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Обо мне 


* Больше 10 лет в разработке 


* Руководил разработкой и поддержкой крупного СМИ 
про киберспорт 


* Сейчас в Авито, пишу бэкенд 
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О чём поговорим 


° Зачем в облако? 

° Как изменится приложение 
* Разные окружения 

* Состав пода 

®° Метрики/логи 

* СТИСО 
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ИИА ЗиИНОп5есигиу 
ке @<$мииОп$еси у 


Опе те |{пед {о ехрат Киретще$ 
{© сотеопе. 
Треп ме бой апт ипаегзапа К. 


16:40 . 06/08/2019 . Тмицег Тог1РПопе 


А зачем в облако? ^ 
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Зачем? 


° Утилизация серверов 
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Зачем? 


° Утилизация серверов 
* Котя ираахе и откат 
* Масштабирование 

* Отказоустойчивость 


° Разные стеки 


Допилим приложение /^ 


Как изменится приложение 


° Статические файлы 

* Внешние ресурсы 

. Сессии 

° Консольные команды 
® Миграции 


* Конфигурация 


12 Гаскогарр 


* Зависимости 

° Конфигурация 

* Сторонние службы 

* Сборка, релиз, выполнение 
° Утилизируемость 


* Паритет окружений разработки и прода 
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Статические файлы 


° Ассеты 
* Загруженные файлы 


* Изображения 


Ассеты 


° В образ 


* СОМ после сборки 


Ороаа$ 


* Не хранить в папке 
° Хранилище отдельно от приложения 
° Внешнее (35) 


° Внутреннее (серв или иное) 
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Изображения 


* Похоже на файлы 

* Прокси для ресайза, вотермарок 
* [пергоху, «Пигтрбог 

° Удобно! 
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Внешние ресурсы 


° База данных 
° Кэш 


. Сессии 


База данных 


* Прод — лучше отдельно 


° [естовые — лучше в кубах 
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Кэш 


® [п-тлегогу 
° В каждом инстансе 


. Общий для всех инстансов 


Сессии 


* По умолчанию лежат в файлах, это не подходит 


* Выносим сессии в ге! /тпетсасре/БД 


Крон и прочие консольные команды 


* Нужен мьютекс 
* Есть в зугтТопу и [агауе! 
* ЧоБи Сгоп4оВ в К8$ 


* Или отдельным контейнером, если хочется, например, 
|агауе| зспеадцег 
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Миграции 


° [аже проблема с одновременным запуском 
® Можно в СТ 


® Можно как Чо и Т1пиСопфатег 


* Оатабазе пиэгачоп м(А К8$ доб апа ТпиСоптатег$ 
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Конфигурация 


ЕР! 
* При запуске, а не сборке 


* Особенности фреймворков и их ОТ 
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Секреты 


° КЗз зесга сз 
° \/ац 
* ЯквУб/=аь уапа ез 


* Можно при старте контейнера складывать в епу 
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Логи 


* Не пишем в файл 
* Отправляем в эзаоц\/заегг 
* Можно Ч5ОМ 


 |о5_еггогз_тахеп в рпр.ап! по умолчанию 1024 байт 
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Приложение готово 


° Статика вынесена отдельно 

* БДи кэш — отдельно 

* Сессии не в файлах 

* Консольные команды и крон в отдельном контейнере 
® Миграции в 1пСоптатег 


* Конфигурация в еп\у 


Среды &% 
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Окружения 


* РгодчсЧоп/завте/оса| 
* Разные внешние ресурсы 
» ЕРМИСЕТ 


° Внутренние зависимости отличаются (рйрипик, хаерив) 
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сотрозег.|оск 


* В репозиторий и в образ 


* Осознанно меняем версии библиотек 
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хаеБиг 


* Нужен локально, а на проде® Стейдже? 


* Но есть оверхед..или нет? 


® Гред собсуждением 


ХаеБи= 


`Э 


Оенск Ве пап$ 
@аепскКг 


В ответ @аг4500п!$ @5ат_АагК и @аз5йт 


Треге 1$ а|5о по гипИйте оуегпеаа К уоц 5е 
хаебия.тоде=оН мПеп изтя Хаериз 3 


ПоскегЕе.Баз!с 


* Его будем катить на прод 
* Общие настройки ({итехопе, модули РНР) 


* СОРУ —гот=сотрозег1а*е${ /чзг/Бт/сотрозег /изг/ 
оса/бт/сотрозег 


* сотрозегтза! —по-ае\у 


° Уменьшаем размер, значит арште и пмизтазе Би|а 
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Поскег!е.зхаге 


* сотрозег тзфа! —Че\ 
* РНРУпК 
* Хаербиз 


Поскег{е.аде\ 


‹ Хаерие (если не сделали раньше) 

® ХПргот 

* Сотрозег 

* Можно запускать в Мш!кире или адоскег-сотрозе 


* Монтируем локальную папку с исходниками 
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Образы — итог 


° Один образ, скорее всего, не получится, но это ок 
° Вазс (ргоа) 

* РНР-ЕРМИСЕТ 

* отазе/ае\ 


® Можно объединять некоторые образы 
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Состав пода 
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Роа 


* Роа — набор запускаемых в К8$ контейнеров 
* Один экземпляр приложения 

* Горизонтальное масштабирование 

* Согатегз & ШпиСоптатегз 


* Контейнеров может быть один или несколько 


Состав типичного пода 


° Приложение (РНР-ЕРМ) 


Настройка РНР-ЕРМ 


° |13теп =12/.0.0.1:9000 

* рт=эзайс 

* рт.тах_сп|агеп=ТО 

* рт.тах_геаце{$=1000 
* рт.зкаби$_раП=/ ийТо 


* рп.ра{П=/Пеа{Пи 


Состав типичного пода 


° Приложение (РНР-ЕРМ) слушает порт 
° Веб-сервер (пепх) 

* Рероцпсег 

* летргоху/Паргоху 


° Сбор метрик/логов (рпр-рт_ехрожщег) 
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Как работает? *» 
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Наблюдаем за работой 
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Наблюдаем за работой 


° | /епез$ ргорбе — проверяем, что доступен /ПеакП2 


* Кеаатезз ргобе — можно проверить, что есть БД и 
кэш, можно прогреть кэши 


* Логи собираем в еазисзеагсй/ега/о> 
* Метрики ризп — можно в геаатез5$ ргоре 


® Метрики ри! — рготееиз 
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СТ/СО 


СТ/СО — как было 


* ры! 
* сотрозег тзка!| 
* глиэгасе ир 


* Меняем эутпИпкК 


СТ/СО — кактеперь 


* Нужен соптатег ге=!$ гу 

* ВиНа 

* Статический анализ и линтеры 
° Тесты 


* Пеплой/откат по кнопке 
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СТ/СО — деплой 


° Готовый образ 
® Миграции 
° Прогрев кэша (например, геа4тезз пробой) 


* Коте ирааге 
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Итог 
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Итог 


* Код соответствует 12 факторам 

* Окружения продуманы, образы описаны 

* Под содержит все нужное 

* Собираем логи и метрики 

* Деплоим и откатываем по нажатию на кнопку 


* Масштабируем, спокойно обновляем сервера 


Что дальше? 


* Для теста можно направить часть трафика в кластер 
* Следим за метриками, тюним ЕРМ и лимиты 
* Нопгопка! Роа Ацозса!пв (НРА) 


* Можно сделать тестовые среды для фичей 


Чеклист переезда в облако 


О ‚ [м] 
ПЕЕО$://си {| погиз!а-с|оца 
ы 
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Полезные материалы 


* ПЕрэ://ЛёТаскогпе/ги/ 
* Статья про заталкивание монолита Авито в КЗ5$ 
* Запуск одного экземпляра консольного приложения в 


Г агуа 


° Статья и доклад Про сетевой обмен в микросервисах 
наРНР 


° Гред с обсуждением оверхеда отхаеБив 


У 


| | | | 
РПР 7’ 


| Обратная связь 


|м в | 
'докладу по ссылкв_ 


@Разазкка. 


 РНРЕ Вова 


#“ ‚ 2022 м 


